草庐IT

iOS 多线程1 --任务与队列

全部标签

ruby-on-rails - Phusion Passenger 如何重用线程和进程?

我正在设置一个Apache2网络服务器,使用PhusionPassenger运行多个RubyonRails网络应用程序。我知道Passenger生成Ruby进程来处理请求。我有以下问题:如果必须同时处理多个请求,Passenger会生成多个进程还是多个(Ruby)线程?如何配置它以使其始终生成单线程进程?如果我有两个Rails应用程序,假设对应用程序A的请求进入进程1,然后对应用程序B的请求到达。进程1是否也可能处理此请求?什么时候以及如何做到这一点?换句话说,是否允许一个进程处理多个Rails应用程序的请求?我在多个URL和多个虚拟主机(例如http://和https://)中导出了

ruby - 将电子邮件组织成线程的算法?

是否有任何命名/著名/特别好的算法来将电子邮件消息组织到线程中?我想在我的网站上添加一个类似于Google网上论坛(和其他邮寄列表)的功能,我只是想知道是否有任何已发布的此类组织算法。我知道推出我自己的算法可能相当容易,但可通过的算法和良好的算法之间的用户体验可能存在很大差异。已在ruby​​中实现的算法的奖励积分! 最佳答案 jwz_threading看起来正是您要的。我没用过。 关于ruby-将电子邮件组织成线程的算法?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - 如何在我的 Rails 应用程序中运行 rake 任务

我想做的事情:在model.rb中,在after_commit中,我想运行rake任务ts:reindexts:reindex通常使用rakets:index运行 最佳答案 如果您希望此rake代码在请求周期内运行,那么您应该避免通过system或任何exec系列(包括反引号)运行rake,因为这将启动一个新的ruby​​解释器并重新加载每次调用Rails环境。相反,您可以直接调用Rake命令,如下所示:-require'rake'classSomeModel注意:在Rails4+中,您将使用Rails.root而不是RAILS_R

ruby - 为什么 EventMachine 的延迟比 Ruby 线程慢?

我有两个使用Mechanize获取Google索引页的脚本。我原以为EventMachine会比Ruby线程更快,但事实并非如此。EventMachine代码成本:“0.24s用户0.08s系统2%cpu12.682总计”Ruby线程代码成本:“0.22s用户0.08s系统5%cpu5.167总计”我是否以错误的方式使用了EventMachine?事件机器:require'rubygems'require'mechanize'require'eventmachine'trap("INT"){EM.stop}EM.rundonum=0operation=proc{agent=Mechan

ruby-on-rails - 我如何调用 Rake 中的另一个任务

尽管这听起来可能与您在此处找到的其他问题相似,但还是有细微差别。我有两个目录,比如/home/rails/Rake和/home/rails/test_app。rails目录是我放置所有rails项目的地方。在Rake内部,我有一个Rakefile和一个create.rake文件。这就是我的rakefile的样子namespace:setupdodesc"something"task:initdoprint"Nameofthedestinationdirectory:"name=STDIN.gets.stripcp_r'.',"../#{name}/lib/tasks"cd"../#{n

ruby - Ruby 的 Net::HTTP 线程安全吗?

Ruby的Net::HTTP线程安全吗?(除了它明确表示不是的version_1_1和version_1_2方法) 最佳答案 我不会指望它。2008年,matzwrote:ForMRI(1.8.x)andYARV(1.9.x),everyCimplementedmethodsareprotectedbyGIL(GlobalInterpreterLock),sothatyoudon'thavetoworryabout.Butitmightdependoneachimplementation.Net::HTTP在stdlib中,这意味着

ruby-on-rails - 从 rake 任务中运行工头

我有以下Rake任务:namespace:foremandotask:devdo`foremanstart-fProcfile.dev`endenddesc"RunForemanusingProcfile.dev"task:foreman=>'foreman:dev'forman命令在shell中运行良好,但是当我运行rakeforeman时,出现以下错误:/Users/me/.gem/ruby/2.0.0/gems/bundler-1.5.2/lib/bundler/rubygems_integration.rb:240:in`blockinreplace_gem':foremani

ruby - Ruby 的线程组有什么用?

我正在浏览Pickaxe,寻找有关Thread的文档,并遇到了ThreadGroup。文档描述了它的作用,但没有解释它的用途。是与线程池相关的线程组,我assumedRubydoesn'thave? 最佳答案 新线程在其父线程组中创建。您可以使用ThreadGroup组织由产生其他线程的父线程给出的隐式树结构,并使用list实例方法获取所有尚未终止的线程,即定义对所有线程进行操作的方法组中的线程。此外,如果您运行不受信任的代码并希望关注它产生的线程,您可以使用enclose来禁止向该组添加(或删除)线程。

ruby-on-rails - 阻塞 IO/Ruby on Rails

我正在考虑使用Rails编写Web应用程序。用户发出的每个请求都取决于调用的外部API。这个外部API可能随机地非常慢(2-3秒),因此显然这会影响单个请求。在代码等待外部API返回的这段时间里,是否会阻塞进一步的用户请求?只是为了进一步澄清,因为似乎有些困惑,这是我期待的模型:Alice向我的网络应用程序发出请求。为此,调用API服务器A。API服务器A很慢,需要3秒才能完成。在Rails应用程序调用API服务器A的这段等待时间内,Bob发出了一个请求,该请求必须向API服务器B发出请求。Ruby(1.9.3)解释器(或Rails3.x框架中的某些东西)是否会阻止Bob的请求,要求他

ruby-on-rails - Sidekiq:确保队列中的所有作业都是唯一的

我有一些更新触发器可以将作业推送到Sidekiq队列中。因此在某些情况下,可以有多个作业来处理同一个对象。有几个唯一性插件("Middleware"、UniqueJobs),它们的文档记录不多,但它们似乎更像是防止重复处理的节流器;我想要的是一个阻止重复创建相同作业的节流器。这样,对象将始终以其最新状态进行处理。有这方面的插件或技术吗?更新:我没有时间制作中间件,但我最终得到了一个相关的清理函数来确保队列是唯一的:https://gist.github.com/mahemoff/bf419c568c525f0af903 最佳答案 简